在 woocommerce 的 wp_admin (shop_order) 页面中覆盖新订单商品的数量

override quantity of new order item in wp_admin (shop_order) page in woocommerce

当店主从 WP-Admin 添加新订单时,我需要覆盖添加的商品数量。目前,我将这个值硬编码为 2。

我试过这个代码:

add_filter('woocommerce_ajax_order_item', 'VNA_add_item_quantity', 10, 2);
function VNA_add_item_quantity($item, $item_id) {
    $item = $item->get_order()->get_item($item_id, false);
    $item->set_quantity(2);
    $item->apply_changes();
    $item->save();
    $item->get_order()->add_item($item);

    return $item;
}

但由于某种原因,它没有反映在订单中,并且继续显示新添加项目的数量=1。我无法弄清楚缺少什么。有人可以帮忙吗?

注:

  1. 默认情况下,传递给我们函数的$item参数是从数据库加载的新对象。所以我正在执行以下代码,以便 order->items 集合中的 $item 对象用于进一步处理。 (将 false 作为第二个参数传递给 get_item()

    $item = $item->get_order()->get_item($item_id, false);
    

    无论我是否使用这段代码,结果都是一样的。

  2. 最后我将 $item 对象添加回 order 只是为了覆盖任何引用。但是没有效果。

根本原因:

当我们调用 $item->get_order() 时,它在内部调用 wc_get_order 其中 returns 一个新的 Order 对象。因此,当我尝试将项目添加回订单(使用 $item->get_order()->add_item($item);)时,它被添加到这个新的订单对象中,而 WC_AJAX::add_order_item() 中的原始订单对象 created/used 保持不变。这就是更改没有反映回来的原因。

解法:

按照@ Woocommerce 的建议,当管理员通过 wp-admin 添加时更新价格 ,我用了woocommerce_ajax_add_order_item_meta这个动作。在这里,我们将原始订单对象的引用作为第 3 个参数,然后我们可以根据需要对其进行操作。这些更改得到正确反映。

代码如下:

add_action( 'woocommerce_ajax_add_order_item_meta', 'VNA_set_item_quantity', 99, 3 );
function VNA_set_item_quantity( $item_id, $item, $order ) {
    foreach ( $order->get_items() as $order_item_id => $order_item_data ) {
        if ( $order_item_id == $item_id ) {

            $qty = 2;

            $order_item_data->set_quantity($qty);
            $order_item_data->set_subtotal($qty * $order_item_data->get_subtotal());
            $order_item_data->set_total($qty * $order_item_data->get_total());

            $order->apply_changes();
            $order->save();
        }
    }
}

一个奇怪的观察是,一旦我们更新了数量,我们还需要更新小计和总计。否则它开始显示 rate = total / qty.

示例:

如果产品成本是 100,它最初显示为:

prod name     | rate   | qty    | total
prod123       | 100    | 1      | 100

现在,如果您只是更改数量,它开始显示为:

prod name     | rate   | qty    | total
prod123       | 50     | 2      | 100

所以出于某种原因,rate 似乎是一个计算字段而不是总计。这就是当我们更新数量时,我们还需要更新小计和总计的原因。这将正确显示为:

prod name     | rate   | qty    | total
prod123       | 100    | 2      | 200

希望这对某人有所帮助。